import api from "../../api/api"
Page({

  /**
   * 页面的初始数据
   */
  data: {
    navActive: 0,
    navArr: [],
    proArr:[],
    loading: true,
    total:-1
  },

  /**
   * 生命周期函数--监听页面加载
   * async : 异步执行方法
   * await ：用于等待一个异步方法执行完 （await只能用于async函数中）
   */
 async onLoad(options) {
    await this.getNavList();
    let navid=this.data.navArr[this.data.navActive]._id
    if(options&&options.navId){
      console.log("收到页面跳转过来的id")
      navid=options.navId
      //找到对应下标
      let navIndex =this.data.navArr.findIndex(o=>o._id===navid)
      this.setData({
        navActive:navIndex
      })
    }
    this.getProductList({navid})
  },
  tabChange(obj){
    //js可选链--> 意思是如果obj没有detail.index属性，就选择??后面的值 (带着三元表达式的方式去理解)
    let index=obj?.detail.index ?? obj;
    let nav=this.data.navArr[index];
    this.setData({
      proArr:[],
      navActive:index
    });
    this.getProductList({
      "navid":nav._id,
    })
  },
  getProductList(data) {
    this.setData({
      loading:true
    })
    api.productList(data).then(res => {
      console.log("商品:",res);
      let oldData=this.data.proArr
      let newData=oldData.concat(res.data)
      this.setData({
        proArr:newData,
        loading:false,
        total:res.total
      })
    })
  },
  async getNavList() {
    await api.listNav().then(res => {
      console.log(res);
      this.setData({
        navArr: res.data
      })
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    if(this.data.total==this.data.proArr.length){
      return;
    }
    //拿到当前nav下标，方式一：
    //let index=this.selectComponent('#myTabs').data.currentIndex;
    let nav=this.data.navArr[this.data.navActive];
    console.log("用户触底的nav下标：",this.data.navActive);
    this.getProductList({
      "navid":nav._id,
      "limit":3,
      "size":this.data.proArr.length
    });
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})